package org.dromara.business.service;

import org.dromara.business.domain.LzshBusinessInfoDataTotal;
import org.dromara.business.domain.bo.LzshTemplateBo;
import org.dromara.business.domain.vo.LzshTemplateVo;
import org.dromara.common.mybatis.core.page.PageQuery;

import java.util.Collection;
import java.util.List;
import java.util.Map;

/**
 * 表单管理Service接口
 *
 * @author Lion Li
 * @date 2024-08-19
 */
public interface ILzshTemplateService {

    /**
     * 查询表单管理
     *
     * @param id 主键
     * @return 表单管理
     */
    LzshTemplateVo queryById(Long id);

    /**
     * 分页查询表单管理列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 表单管理分页列表
     */
    List<LzshTemplateVo> queryPageList(LzshTemplateBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的表单管理列表
     *
     * @param bo 查询条件
     * @return 表单管理列表
     */
    List<LzshTemplateVo> queryList(LzshTemplateBo bo);

    /**
     * 新增表单管理
     *
     * @param bo 表单管理
     * @return 是否新增成功
     */
    Boolean insertByBo(LzshTemplateBo bo);

    /**
     * 修改表单管理
     *
     * @param bo 表单管理
     * @return 是否修改成功
     */
    Boolean updateByBo(LzshTemplateBo bo);

    /**
     * 校验并批量删除表单管理信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    long queryCount(LzshTemplateBo bo);

    Map<String, List<LzshBusinessInfoDataTotal.totalData2>> getTemplateNum();
}
